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Microcontroller With An Interrupt Structure Having Programmable Priority 
Levels With Each Priority Level Associated With a Different Register Set 

[001] The invention relates to the field of processor architecture and more specifically 
to the field of data register architecture for use with microcontrollers. 

[002] Program stream data is typically stored in a memory circuit, where the 
instructions encoded within the program data for a particular routine are executed by a 
processor, when an interrupt occurs, one program stream interrupts the execution of 
another one. The multiple instructions making up each program stream are stored at a 
specific location in the memory circuit. The program stream instructions allow the 
processor to carry out various tasks. Instructions from each program stream are typically 
sequentially retrieved and processed one at a time. 

[003] While processing instructions from a program stream, the processor utilizes 
program registers. These registers are memory locations within the processor that support 
very high speed direct access by the microprocessor. For example, some operations are 
specifically for processing data directly within the registers. Program stream data read 
from the memory circuit is stored in these registers and the processor performs logical 
and arithmetic operations on the values stored therein. When the execution of a first 
program stream becomes interrupted by a second other program stream, the contents of 
the program registers corresponding to the first program stream are typically stored 
elsewhere in order to allow the interrupting program to utilize the same set of program 
registers. Once the interrupting program-second program stream- has completed its 
sequence of instructions, the contents of the program registers corresponding to the first 
program stream are restored and execution of the first program stream resumes at a 
subsequent program counter at which the interruption occurred. Thus, all information 
corresponding to the first program stream is typically saved prior to servicing of the 
interrupting second program stream. 

[004] Of course, with such a system, it must be guaranteed that all interrupted 
program stream parameters are restored before the execution of the first program stream 
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resumes. If during this transfer an interrupt occurs, then all data may not be stored or 
restored. If the error free storage of the program register contents and other critical first 
program stream data does not occur, the processor has no way of knowing whether the 
first program stream data restored to the registers has become corrupt or not. In order to 
ensure that all first program stream data is transferred, the interrupting task must wait 
until the restoration process is completed, which wastes valuable processing time and 
results in increased power consumption. 

[005] A need therefore exists to facilitate processing of interrupting program streams 
without storing and restoring interrupted program stream critical data. It is therefore an 
object of the invention to provide a system for facilitating the execution of an interrupting 
program stream without storing and restoring interrupted program stream critical data. 

Summary of the Invention 

[006] In accordance with the invention there is provided a system comprising a 
processor; a plurality of register bank blocks; and, a register bank block decoder circuit 
for activating one and only one of the plurality of register bank blocks, the register bank 
block decoder circuit responsive to interrupt event operations for selecting the one of the 
plurality of register bank blocks for being activated, where different interrupt event 
operations result in selection of different ones of the plurality of register bank blocks. 

[007] In accordance with the invention there is provided a method of switching 
processing resources in a data processing system comprising the steps of: providing a 
plurality of register bank blocks; utilizing a first register bank block from the plurality of 
register bank blocks for data processing; receiving of an interrupt request for initiating an 
interrupt event; determining if the interrupt request is to be fulfilled, and if so, then 
selecting a second register bank block from the plurality of register bank blocks, the 
selected second register bank block in isolation from the first register bank block; and, 
utilizing the second register bank block from the plurality of register bank blocks for data 
processing. 
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[008] In accordance with the invention there is provided a storage medium having 
data stored thereon, the data for implementation of a processing system comprising: first 
instruction data for providing a plurality of register bank blocks; and, second instruction 
data for providing a register bank block decoder circuit for activating one of the plurality 
of register bank blocks in isolation, the register bank block decoder circuit responsive to 
interrupt event operations for selecting the one of the plurality of register bank blocks for 
being activated, where different interrupt event operations result in selection of different 
ones of the plurality of register bank blocks. 

[009] Exemplary embodiments of the invention will now be described in conjunction 
with the following drawings, in which: 

[0010] FIG. 1 illustrates a very large scale integration (VLSI) Peripheral Bus Bridge 
(VPB bridge), as a high level diagram, in accordance with a first embodiment of the 
invention; 

[0011] FIG. 2 illustrates the VLSI Peripheral Bus Bridge (VPB bridge) shown in FIG. 
1, as a low level diagram, showing circuit blocks making up the VPB Bridge; 

[0012] FIG. 3 illustrates four 8-bit registers, for example BankO registers VPBD0 to 
VPBD3; 

[0013] FIG. 4 illustrates a Debug Bank Select (DBSEL) register, where the DBSEL 
register is provided for enhanced debug visibility of the VPB data register banks; 

[0014] FIG. 5 illustrates a high level diagram of special function register (SFR) block 
used within the VPB bridge; 

[0015] FIG. 6 illustrates a register bank block that comprises six 8-bit data register, for 
example registers VPBD0 through VPBD5 corresponding to BankO through Bank5 and 
an input data multiplexer (MUX); 

[0016] FIG. 7 illustrates a register bank decoder circuit that includes the VPB data 
register bank decoder; 
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[0017] FIG. 8 illustrates an address decoder circuit used for decoding of an ic__pri_top 
signal to generate register bank select signals; 

[0018] FIG. 9 illustrates a VPB bridge control block circuit for generating of pnres, 
pstb and pwrite control signals; 

[0019] FIG. 10 illustrates a VPB bridge state machine diagram; and, 

[0020] FIG. 1 1 illustrates a flowchart showing a sequence of events that occur for 
executing of program streams using the VPB bridge. 

[0021] FIG. 1 illustrates a very large scale integration (VLSI) Peripheral Bus Bridge 
(VPB bridge) 100, as a high level diagram, in accordance with a first embodiment of the 
invention. A processor 180, or microcontroller, is coupled to the VPB bridge 100 and to a 
memory circuit 182, in the form of a random access memory (RAM), or external high 
data memory (HDATA). Disposed within the processor is a plurality of general special 
function registers (GSFRs) disposed within a general special function register (GSFR) 
block 181. A first plurality of input ports is provided on the VPB bridge for receiving of 
input signals and a second plurality of output ports is provided thereon for providing of 
output signals. Table 1 illustrates the input and output signals that are provided to and 
from the VPB bridge 100. 

[0022] As illustrated in FIG. 1, two peripheral devices 191 and 192 are connected to 
the 32 bit peripheral data output bus, pdo[3 1 :0] 152 and to the 32 bit peripheral data input 
bus, pdi[31:0] 151. The peripheral 0 select signal, pselO, is provided to an enable port on 
the first peripheral device 191 and the peripheral 1 select signal, psell, is provided to an 
enable port on the second peripheral device 192. The peripheral select signals, pselO to 
psel31 listed in Table 1, are used to selectively enable and disable the peripheral devices 
191 and 192. Input and output signals provided to and from the VPB bridge 100 are 
summarized in Table 1 . 



Name 


Direction 


Width 


Function 


mx1_clk 


IN 


1 


Clock Signal 


mx1__reset 


IN 


1 


Reset Signal 
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Name 


Direction 


Width 


Function 


mx1_pbus_adr 


IN 


8 


Peripheral bus (Pbus) Special Function 
Register (SFR) address 


mx1_pbus_wr 


IN 


1 


Pbus write select signal 


mx1 _pbus_rd 


IN 


1 


Pbus read select signal 


mx1_pbus_out 


IN 


8 


Write data for the selected VPB SFR register. 


ic _pri_top[2:0] 


IN 


3 


VPB data register bank selection. 

000 - Bank 0, No interrupt are active. 

001 - Bank 1, Interrupt of priority level 0 is 

active. 

010 - Bank 2 f Interrupt of priority level 1 is 

active 

01 1 - Bank 3, Interrupt of priority level 2 is 

active 

100 - Bank 4, Interrupt of priority level 3 is 
active 

101- Rsink ^ Intern int nf nrinritv A. 

(Debug Interrupt) is active 
110- Selects bank 0 
1 1 1 - Selects bank 0. 


mx1_id_xdrd_n 


IN 


1 


HDATA read signal. 


mx1_id_xdwr_n 


IN 


1 


HDATA write signal. 


mx1_vpb_acc 


IN 


1 


Mpmnrv arlffrp<;«; ripr*nripr iHpntifi**Q th^ tarnot 
ivici i iui y auui coo ucuuuci iuci mi ico Lilt? Lai yd 

address as a VPB access. 


mx1_pbus_in 


OUT 


8 


Read data from the selected VPB register. 
Assigned 0x00 when the VPB registers are 

I1UL oclcUlcU IUI ItJdU UptJI dllUil. 


mx1 acu xadr 18 
to14 


IN 


5 


nUn 1 r\ 1 1 Id 1 IUI y dUUI coo UUb. dull XdUl ^ 1 O.UJ 

is not routed through the bridge. 
acu_xadr[18:14] is decoded to select the VPB 
peripheral. 


pnres 


OUT 


1 


Active LOW signal to reset the VPB devices. 


pstb 


OUT 


1 


Sinnal from thp VPR hrirlnp to tim*» rlata 

vJiyiiai iivjiii ii ic v i lj u\ njyc lu iiiiio Uala 

transfer cycles on the i peripheral bus. 


pwrite 


OUT 




Data transfer direction. HIGH indicates a 

nprinhpral write pv/pIp 1 DW inHinatoc a roaH 
pci ipi ici ai wine uyoic lwv II lUIL/dluo d ledU 

cycle. 


pdo 


OUT 


32 


VPB peripheral data output bus. pdo[7:0] = 

vnbdO Ddon^'Sl = vnhH1 nHnr^'Vlfil = \/nhrl9 

and pdo[31 :24] = vpbd3. 


pdi 


IKI 

IN 


32 


VPB peripheral data input bus. vpbdO = 
pdi[7:0] f vpbdl = pdi[15:8], vpbd2 = pdi[23:16] 
and vpbd3 = pdi[31:24]. 


pselO 


OUT 


1 


VPB peripheral 0 select signal. 


pseM 


OUT 


1 


VPB peripheral 1 select signal. 
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Name 


Direction 


Width 


Function 


psel2 


OUT 


1 


VPB peripheral 2 select signal. 


psel3 


OUT 


1 


VPB peripheral 3 select signal. 


psel4 


OUT 


1 


VPB peripheral 4 select signal. 


pse!5 


OUT 


1 


VPB peripheral 5 select signal. 


psel6 


OUT 


1 


VPB peripheral 6 select signal. 


psel7 


OUT 


1 


VPB peripheral 7 select signal. 


psel8 


OUT 


1 


VPB peripheral 8 select signal. 


psel9 


OUT 


1 


VPB peripheral 9 select signal. 


pseMO 


OUT 


1 


VPB peripheral 10 select signal. 


psel11 


OUT 


1 


VPB peripheral 1 1 select signal. 


psel12 


OUT 


1 


VPB peripheral 12 select signal 


pse!13 


OUT 


1 


VPB peripheral 13 select signal 


psel14 


OUT 


1 


VPB peripheral 14 select signal 


psel15 


OUT 


1 


VPB peripheral 15 select signal 


pse!16 


OUT 


1 


VPB peripheral 16 select signal 


psel17 


OUT 


1 


VPB peripheral 1 7 select signal 


pse!18 


OUT 


1 


VPB peripheral 18 select signal 


psel19 


OUT 


1 


VPB peripheral 19 select signal 


pse!20 


OUT 


1 


VPB peripheral 20 select signal 


pse!21 


OUT 


1 


VPB peripheral 21 select signal 


psel22 


OUT 


1 


VPB peripheral 22 select signal 


psel23 


OUT 


1 


VPB peripheral 23 select signal 


psel24 


OUT 


1 


VPB peripheral 24 select signal 


pse!25 


OUT 


1 


VPB peripheral 25 select signal 


psel26 


OUT 


1 


VPB peripheral 26 select signal 


psel27 


OUT 


1 


VPB peripheral 27 select signal 


pse!28 


OUT 




VPB peripheral 28 select signal 


psel29 


OUT 




VPB peripheral 29 select signal 


pse!30 


OUT 




VPB peripheral 30 select signal 


psel31 


OUT 




VPB peripheral 31 select signal 



Table 1. Input and Output Signals Provided to and From the VPB bridge 
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[0023] Though, only 32 VPB peripheral device select signals are listed in Table 1, the 
VPB bridge is not limited to only 32 peripheral device select signals, the number of 
peripheral device select signals is a matter of design choice. 

[00241 FIG. 2 illustrates a low level diagram of the VPB bridge 100 shown in FIG. 1 . 
The VPB bridge 100 enables interfacing of a plurality of output switching circuits, in the 
form of 8 bit output multiplexers (MUXs), 1 1 1, 1 12, 1 13 and 1 14, to the 32 bit peripheral 
data output bus, pdo[31:0], coupled to the peripheral devices, 191 and 192, for providing 
of a 32-bit output signal thereto. A first output MUX 111 provides a first set of 8 data 
output bits, pdo[7:0], a second output MUX 1 12 provides a second set of 8 data output 
bits, pdo[15:8], a third output MUX 113 provides a third set of 8 data output bits, 
pdo[23: 16], and a fourth output MUX 1 14 provides a fourth set of 8 data output bits, 
pdo[31 :24]. The first through fourth set of 8-bit data output signals make up the 32-bit 
data output signal provided to the 32 bit peripheral devices. Likewise, the peripheral 
devices provide a 32-bit output signal to the bridge 100 on a peripheral data input bus, 
pdi[31 :0]. A first set of 8-bit input signals, pdi[7:0] is provided to input ports of a first 
input MUX 13 1, a second set of 8-bit input signals, pdi[15:8] is provided to input ports of 
a second input MUX 132, a third set of 8-bit input signals, pdi[23:16] is provided to input 
ports of a third input MUX 133, and a fourth set of 8-bit input signals, pdi[31:24] is 
provided to input ports of a fourth input MUX 134. 

[0025] A first set of six 8-bit registers, 120a through 125a, belonging to a plurality of 
register bank blocks, BankO to Bank5, is coupled between six 8-bit output ports of a first 
input switching circuit in the form of a first input MUX 131 and six 8-bit input ports of 
the first output MUX 111. This first set of registers is for storing of 8-bits of data 
received from the peripheral data input bus, pdi[7:0]. 

[0026] A second set of six 8-bit registers, 120b through 125b, belonging to a plurality 
of register bank blocks, BankO to Bank5, is coupled between six 8-bit output ports of the 
second switching circuit in the form of a second input MUX 132 and six 8-bit input ports 
of the second output MUX 1 12. This second set of registers is for storing of 8-bits of data 
received from the peripheral data input bus, pdi[15:8]. 
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[0027] A third set of six 8-bit registers, 120c through 125c, belonging to a plurality of 
register bank blocks, BankO to BankS, is coupled between six 8-bit output ports of the 
third input switching circuit in the form of a third input MUX 133 and six 8-bit input 
ports of the third output MUX 113. This third set of registers is for storing of 8-bits of 
data received from the peripheral data input bus, pdi[23: 16]. 

[0028] A fourth set of six 8-bit registers, 120d through 125d, belonging to a plurality of 
register bank blocks, BankO to BankS, is coupled between six 8-bit output ports of the 
fourth input switching circuit in the form of a fourth input MUX 134 and six 8-bit input 
ports of the fourth output MUX 1 14. This fourth set of registers is for storing of 8-bits of 
data received from the peripheral data input bus, pdi[31:24]. Registers 120a, 120b, 120c 
and 120d form a first register bank block 120 from the plurality of register bank blocks. 
Registers 121a, 121b, 121c and 121d form a second register bank block 121 from the 
plurality of register bank blocks. Registers 122a, 122b, 122c and 122d form a third 
register bank block 122 from the plurality of register bank blocks. Registers 123a, 123b, 
123c and 123d form a fourth register bank block 123 from the plurality of register bank 
blocks. Registers 124a, 124b, 124c and 124d form a fifth register bank block 124 from 
the plurality of register bank blocks. Registers 125a, 125b, 125c and 125d form a sixth 
register bank block 125 from the plurality of register bank blocks. 

[0029] FIG. 3 illustrates four 8-bit registers, for example BankO registers VPBD0 to 
VPBD3, 120a through 120d. These registers allow 8 bit data transfer to the input ports of 
the output MUXs, 111, 112, 113 and 1 14, and 32-bit data transfers to the peripheral 
devices connected to the output ports thereof. Reading or writing of 32 bits of data on the 
output MUX output port side is performed in 4 steps of 8-bit read or write operations, 
respectively. FIG. 4 illustrates a Debug Bank Select (DBSEL) register 150, where the 
DBSEL register 150 is provided for enhanced debug visibility of the data register banks, 
BankO to BankS. This register is preferably read and written when a debug interrupt is 
active. 

[0030] FIG. 5 illustrates a high level diagram of special function register (SFR) block 
501 used within the VPB bridge 100. The SFR block 501 is used for implementing of the 
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VPBDO, VPBD1, VPBD2, VPBD3 registers used within register banks BankO to BankS. 
Additionally, the SFR block 501 is used for implementing of the DBSEL register 150. 
Table 2 illustrates the input and output signals that are provided to the SFR block 501. 



Name 


Direction 


Width 


Function 


pbus_adr 


IN 


8 


Peripheral bus address from the gsfr block. 


pbus out 


IN 


8 


Pprinhpral data innut from thp n^fr hlnpk 

1 * — 1 r ^ — MILfUl II Ul I 1 11 1 Kj UOII UIUbl\i 


pbus_we 


IN 




Peripheral write strobe from the gsfr block. 


pbus_rd 


IN 




Peripheral read strobe from the gsfr block. 


pdi 


IN 


32 


Data input from VPB peripheral device. 


mx1_id_xdrd_n 


IN 


1 


HDATA read signal. Used to detect VPB read. 


mx1_vpb_acc 


IN 


1 


Memory address decoder identifies the target address 
as a VPB access. Used to detect vpb read 


pstb 


IN 


1 


Signal from a VPB control block to time data transfer 
cycles. Used to detect vpb read. 


b0_sel 


IN 


1 


Data Register Bank 0 select signal. Masked or actual 
Interrupt priority level is 0. 


b1__sel 


IN 




Data Register Bank 1 select signal. Masked or actual 
Interrupt priority level is 1 . 


hO col 


IK) 




Data Register Bank 2 select signal. Masked or actual 
Interrupt priority level is 2. 


b3_se1 


IN 


1 


Data Register Bank 3 select signal. Masked or actual 

Intern int nrinritv/ Ipv/aI iq *^ 
ii uci i upi yjuxji t\y icvci 10 o. 


b4_sel 


IN 


1 


Dflta RpniQfpr Rank A colo/^t cinnsal MaclroH r\r arfi iol 

Interrupt priority level is 4. 


b5_sel 


IN 




Data Register Bank 5 select signal. Masked or actual 
Interrupt priority level is 5. 


elk 


IN 




CPU clock input. 


reset 


IN 




CPU reset input. 


pbusjn 


OUT 


8 


Peripheral data output to the GSFR block. 


pdo 


OUT 


32 


Data output signal to VPB peripheral device. 


dbsel_en 


OUT 


1 | 


Bit 3 of DBSEL register. 


dbseLpri 


OUT 


3 


Bit 2 - Bit 0 of DBSEL register. 



Table 2. Input and Output Signals Provided to and From the SFR Block 
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[0031] Input ports 502 are used for receiving data register bank select signals for 
selecting of a register bank to activate for access thereto. Disposed within the SFR block 
501 are the first through fourth input MUXs, 131 to 134, the first through fourth register 
banks, and the first through fourth output MUXs, 111 to 114. 

[0032] FIG. 6 illustrates a register bank block 601 that comprises six 8-bit data 
registers, for example registers VPBD0 through VPBD5 corresponding to BankO through 
Bank5 and an input data MUX 131 (FIG. 2). Four register bank blocks 601 are used 
within the VPB bridge 100 with each coupled to a respective data output MUX. As is 
illustrated in FIG. 2, a first register bank block includes input MUX 131 and BankO 
through Bank5 VPBD0 registers, 120a through 125a. A second register bank block 
includes input MUX 132 and BankO through Bank5 VPBD1 registers, 120b through 
125b. A third register bank block includes input MUX 133 and BankO through Bank5 
VPBD2 registers, 120c through 125c. A fourth register bank block includes input MUX 
134 and BankO through Bank5 VPBD3 registers, 120d through 125d. The first through 
fourth register bank blocks are coupled to first through fourth input ports of the data 
output MUXs, 111, 112, 113, and 114, respectively. Input and output signals provided to 
and from a single register bank are summarized in Table 3. 



Name 


Direction 


Width 


Function 


pdi__8bits 


IN 


8 


8 bit input data from the VPB peripheral. 


pbus_out 


IN 


8 


Peripheral data input from the gsfr block. 


reg_w 


IN 




Register write strobe. 


vpb_rd 


IN 




VPB read. Used to switch input data mux. 


b0_sel 


IN 




Data Register Bank 0 select signal. Masked or actual 
Interrupt priority level is 0. 


b1_sel 


IN 




Data Register Bank 1 select signal. Masked or actual 
Interrupt priority level is 1 . 


b2_sel 


IN 




Data Register Bank 2 select signal. Masked or actual 
Interrupt priority level is 2. 


b3_sel 


IN 




Data Register Bank 3 select signal. Masked or actual 
Interrupt priority level is 3. 


b4_sel 


IN 




Data Register Bank 4 select signal. Masked or actual 
Interrupt priority level is 4. 
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Name 


Direction 


Width 


Function 


b5_sel 


IN 


1 


Data Register Bank 5 select signal. Masked or actual 
Interrupt priority level is 5. 


CIK 


IKI 
1 IN 


A 
1 


oku ciock signal. 


reset 


IN 


1 


CPU reset signal. 


pdo_8bits 


OUT 


8 


Data output to the VPB SFR block and VPB peripheral 
devices. 



Table 3. Input and Output Signals Provided to and From a single register bank 



[0033] FIG. 7 illustrates a register bank block decoder circuit 701 that includes the 
VPB data register bank decoder 140. The register bank block decoder circuit 701 is 
responsive to interrupt event operations for selecting one of the plurality of register bank 
blocks for being activated, where different interrupt event operations result in selection of 
different ones of the plurality of register bank blocks. Furthermore, the register bank 
block decoder circuit 701 functions as an interrupt priority determination logic circuit that 
receives an interrupt request and determines a priority of the interrupt request. In 
dependence upon the determined priority, the register bank decoder circuit 701 provides a 
register bank block selection signal, bankO sel, bankl_sel, bank2_sel, bank3_sel, 
bank4_sel, and bank5_sel, to a respective bank selection input port, 602a through 602f, 
from the plurality of bank selection input ports 602. Referring to Table 4, input and 
output signals provided to and from the register bank decoder circuit are summarized. 



Name 


Direction 


Width 


Function 


icj3ri_top 


IN 


3 


Interrupt priority level, used to generate data register bank 
select signal. 


dbsel_en 


IN 




Bit 3 of DBSEL SFR. 


dbsel_pri 


IN 




Priority level from DBSEL SFR. 


b0_sel 


OUT 




Data Register Bank 0 select signal. Masked or actual 
Interrupt priority level is 0. 


b1_sel 


OUT 




Data Register Bank 1 select signal. Masked or actual 
Interrupt priority level is 1 . 


b2_sel 


OUT 




Data Register Bank 2 select signal. Masked or actual 
Interrupt priority level is 2. 


b3_sel 


OUT 




Data Register Bank 3 select signal. Masked or actual 
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Name 


Direction 


Width 


Function 








Interrupt priority level is 3. 


b4_sel 


OUT 


1 


Data Register Bank 4 select signal. Masked or actual 
Interrupt priority level is 4. 


b5_sel 


OUT 


1 


Data Register Bank 5 select signal. Masked or actual 
Interrupt priority level is 5. 



Table 4. Input and Output Signals Provided to and From the register bank decoder 

circuit 



[0034] The register bank decoder circuit 701 decodes the icjpri_top signal to generate 
register bank select signals at register bank select output ports 702. These register bank 
select output ports 702 are coupled to register select input ports 502 of the SFR block 
501. This circuit 702 also detects debug interrupt level and uses a dbseljpri input signal 
to generate select signals if a dbsel en signal is set. 

[0035] FIG. 8 illustrates an address decoder circuit 801 used for decoding of the 
ic __pri_top signal to generate register bank select signals. Input and output signals 
provided to and from the address decoder circuit 801 are summarized in Table 5. 



Name 


Direction 


Width 


Function 


mx1_ypb_acc 


IN 


1 


Memory address decoder identifies the 
target address as a VPB access. 


mx1 acu xadr 18to1 
4 


IN 


5 


HDATA memory address bus. 
acu_xadr[13:0] is not routed through the 
VPB bridge. acu_xadr[18:14] is decoded to 
select the VPB peripheral device. 


pselO 


OUT 




VPB peripheral 0 select signal. 


pseM 


OUT 




VPB peripheral 1 select signal. 


psel2 


OUT 




VPB peripheral 2 select signal. 


pse!3 


OUT 




VPB peripheral 3 select signal. 


psel4 


OUT 




VPB peripheral 4 select signal. 


pselS 


OUT 




VPB peripheral 5 select signal. 


pse!6 


OUT 




VPB peripheral 6 select signal. 


pse!7 


OUT 




VPB peripheral 7 select signal. 



12 



PHUS030254WO 



Name 


Direction 


Width 


Function 


psel8 


OUT 


A 


VPB peripheral 8 select signal. 


pse!9 


OUT 


! 


VPB peripheral 9 select signal. 


pseHO 


OUT 


1 


VPB peripheral 10 select signal. 


psel11 


OUT 


i 


VPB peripheral 1 1 select signal. 


pse!12 


OUT 


1 


VPB peripheral 12 select signal. 


pse!13 


OUT 


! 


VPB peripheral 13 select signal. 


psel14 


OUT 




VPB peripheral 14 select signal. 


psel15 


OUT 




VPB peripheral 15 select signal. 


pse!16 


OUT 


! 


VPB peripheral 16 select signal. 


pse!17 


OUT 


! 


VPB peripheral 17 select signal. 


psel18 


OUT 


! 


VPB peripheral 18 select signal. 


pse!19 


OUT 


! 


VPB peripheral 19 select signal. 


psel20 


OUT 


-1 


VPB peripheral 20 select signal. 


psel21 


OUT 


! 


VPB peripheral 21 select signal. 


pse!22 


OUT 


! 


VPB peripheral 22 select signal. 


psel23 


OUT 


i 


VPB peripheral 23 select signal. 


psel24 


OUT 


i 


VPB peripheral 24 select signal. 


psel25 


OUT 


1 


VPB peripheral 25 select signal. 


pse!26 


OUT 


! 


VPB peripheral 26 select signal. 


psel27 


OUT 


1 


VPB peripheral 27 select signal. 


psel28 


OUT 


1 


VPB peripheral 28 select signal. 


pse!29 


OUT 




VPB peripheral 29 select signal. 


pse!30 


OUT 




VPB peripheral 30 select signal. 


pse!31 


OUT 




VPB peripheral 31 select signal. 



Table 5. Input and Output Signals Provided to and from the address decoder circuit 



[0036] FIG. 9 illustrates a VPB control block circuit 901 for generating of pnres, pstb 
and pwrite control signals. Table 6 summarizes the input and output signals provided to 
and from the VPB control block circuit 901 . 
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Name . 


Direction 


Width 


Function 


mx1 _id_xdrd_n 


IKI 

IN 


1 


HDATA read signal. Used to detect vpb read. 


mx 1 _id_xdwr_n 


IKI 

IN 


1 


HDATA write signal. Used to detect vpb write. 


mx1_vpb__acc 


IN 


1 


Memory address decoder identifies the target address 
as a VPB access. Used to detect vpb read or write. 


elk 


IN 


1 


clock input. 


reset 


IN 




reset input. 


pnres 


OUT 


1 


Active LOW signal to reset the VPB devices. 


pstb 


OUT 




Signal from the VPB bridge to time data transfer cycles 
on the peripheral bus. 


Pwrite 


OUT 




Data transfer direction. HIGH indicates a peripheral 
write cycle. LOW indicates a read cycle. 



Table 6. Input and Output S 



gnals Provided to and from the VPB address decoder 
circuit 



[0037] Referring back to FIGs. 1 and 2, processes of writing of 32-bit data to the input 
ports of the output MUXs is performed in 4 steps - 4 8-bit write operations. A process of 
reading of 32-bit data from the output ports of the data input MUXs is performed in 4 
steps - 4 8-bit read operations. Advantageously, these operations are interruptible during 
any step, since each interrupt level is provided with a private bank of VPBDO - VPBD3 
registers. At any given time, preferably a maximum of 6 interrupt levels are activatable in 
the present exemplary embodiment. Switching between the banks of registers is 
controlled by an interrupt priority level signal (ic_pri_top) and the DBSEL SFR 150. 

[0038] FIG. 10 illustrates a VPB bridge state machine diagram, wherein data is 
transferred using the VPB bridge when the following relation is satisfied: 

xfer_start <= mxl_vpb_acc AND ((NOT mxl_id_xdrd_n) OR (NOT mxl _id_xdwr_n)) 

[0039] The VPB bridge 100 remains idle, step 1001, while xfer_start=0, once 
xfer_start=l, setup operations are performed, where the output signals and the ports for 
receiving of input signals are selected, in step 1002. Once setup is complete, a strobe 
signal is provided, step 1003, and the output signals are provided from the VPB bridge 
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100 and the input signals are received by the VPB bridge. Thereafter, the VPB bridge 100 
returns to an idle state, step 1001. 

[0040] Referring to FIG. 1 1, a flowchart is shown that illustrates a sequence of events 
that occur for executing of program streams using the VPB bridge 100. The processor 
180 is used to execute each of the program streams. A N th VPB peripheral device begins 
execution of a N th program stream having a N th interrupt priority using a N th bank of 
registers, in step 1 101. A request is made by a (N+l) th VPB peripheral device for 
executing of a (N+l) th program stream having a (N+l) th priority for interrupting of the 
N th program stream, step 1 102. A determination is made as to whether the priority of the 
(N+l) th program stream is higher than the N th program stream, in step 1 103. If so, then 
processing of the N th program stream by the processor 180 is interrupted and a (N+l) th 
bank of registers is switchably coupled to the processor for processing of the (N+l) th 
program stream, in step 1 104. Processing of the (N+l) th program stream commences 
using the (N+l) th bank of registers, in step 1 105. A request is now made by a (N+2) th 
VPB peripheral device for executing of a (N+2) th program stream having a (N+2) th 
priority for interrupting of the (N+l) th program stream, in step 1 106. A determination is 
made as to whether the priority of the (N+2) th program stream higher than the (N+l) th 
program stream, in step 1 107. If so, then processing of the (N+l) th program stream is 
interrupted and a (N+2) th bank of registers are provided to the processor for processing of 
the (N+2) th program stream, in step 1 108. The processor 180 then uses the (N+2) th bank 
of registers to process the (N+2) th program stream, in step 1 109. Once the processing of 
the (N+2) th program stream is finished, in step 1110, the processor is switched to the 
(N+l) th register bank, in step 1111, and processing of (N+l) th program stream is finished, 
in step 1112. Thereafter, the N th register bank is switched to, step 1113, and processing of 
N th program stream is finished 1114. 

[0041] Thus, if there are N levels of interrupt priority then N+l register bank blocks are 
provided, which also includes the case where no interrupts are active. If the VPB 
peripheral device is performing a transfer of data to or from the bank registers and an 
interrupt of higher priority occurs, and is accepted, then a different set of register banks 
are made accessible to the interrupting second program stream. These interruptions and 
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provisions of new register banks occur up to a maximum interrupt priority. Once the 
highest priority program stream completes, then the next lower one is directed to continue 
until it completes or is interrupted again by a higher interrupt priority program stream. 
Thus, completion of VPB peripheral information transfer is facilitated for any sequence 
of interrupts, with no requirements being placed on any interrupt routines to store and 
restore any SFR information. 

[0042] For the exemplary architecture illustrated, at any time, a maximum number of 
active interrupt levels preferably does not exceed 6. Each interrupt level is provided with 
a private bank of VPBDO - VPBD3 registers for exclusive use by that interrupt. By 
implementing different register banks for use by different interrupting program streams, 
save and restore register operations in the interrupt handler are obviated. This saves 
valuable processing resources and provides reduced power consumption, since every time 
that a store and restore operation is performed, logic gates are enabled and disabled, thus 
wasting electrical power. That said, the faster the processing time for storing and 
restoring registers, the more power that is consumed by the processing system. 

[0043] Of course, for system debugging purposes, when the debug mode is active, all 
register banks are accessible. By setting bit D3, EN, in the DBSEL register 150. Bits DO - 
D2 of DBSEL register are used to select the bank. Advantageously, the VPB bridge 100 
implements 3 clock VPB bus cycle and does not support "perr" and "prdy" signals. Each 
VPB peripheral is allocated memory space within the memory circuit 182. Address lines 
and clock signals for VPB peripherals are not routed through the bridge. Memory address 
lines (mxl_acu_xadr[13:0]) are directly connected to the peripheral address lines 
(pa[13:0]). CPU clock (mxl clk) is directly connect to the peripheral clock(pclk). For the 
current implementation shown, up to 32 peripherals are supported by the VPB bridge 
100. Of course, the VPB bridge is expandable for use with any number of VPB 
peripherals by modifying the VPB address decoder 801. 

[0044] The above described embodiment of the invention relieves the interrupting 
program stream from storing and restoring the contents of any VPB peripheral access that 
may have been underway before the interrupting program stream was directed to interrupt 
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and begin execution. As a result, processing time, as well as code space is saved. Also, 
the compiler does not have to include instruction code for saving and restoring of SFR 
contents, thus the compiler design is simplified and less instructions are utilized in the 
compiled program streams. 

[0045] The VPB bridge 100, shown in the example embodiments of the invention, is 
applicable for use with an 805 1 processor core, known to those of skill in the art, where 
the 8051 microcontroller typically employs 4 interrupt priority levels. For example, the 
VBO bridge 100 is used within a 80C51 MX1 core ® microcontroller architecture 
manufactured by Philips semiconductors. Of course, the VPB bridge 100 is applicable to 
many other processor architectures. 

[0046] Optionally, the register bank block decoder circuit 140 also includes a circuit 
140a for storing and retrieving of register bank block selection data derived from the 
register bank block selection signal of a pre interrupt switch state, wherein upon 
terminating of an interrupt event the input switching circuit and the output switching 
circuit are provided with the pre interrupt register bank block selection signal derived 
from the stored bank block selection data. 

[0047] Numerous other embodiments may be envisaged without departing from the 
spirit or scope of the invention. 
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